From ec567e5fad4c97c051cbe002303332bf7e97daf7 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Sun, 8 Mar 2015 09:11:51 -0400 Subject: [PATCH] Add a test for builder-constructed file filters --- testsuite/gtk/builder.c | 43 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/testsuite/gtk/builder.c b/testsuite/gtk/builder.c index 1ae779c3e5..deb4e5436d 100644 --- a/testsuite/gtk/builder.c +++ b/testsuite/gtk/builder.c @@ -2983,6 +2983,48 @@ test_anaconda_signal (void) g_object_unref (builder); } +static void +test_file_filter (void) +{ + GtkBuilder *builder; + GObject *obj; + GtkFileFilter *filter; + GtkFileFilterInfo info; + + const gchar buffer[] = + "" + " " + " " + " text/plain" + " image/*" + " " + " " + " *.txt" + " *.png" + " " + " " + ""; + + builder = builder_new_from_string (buffer, -1, NULL); + obj = gtk_builder_get_object (builder, "filter1"); + g_assert (GTK_IS_FILE_FILTER (obj)); + filter = GTK_FILE_FILTER (obj); + g_assert_cmpstr (gtk_file_filter_get_name (filter), ==, "filter1"); + g_assert (gtk_file_filter_get_needed (filter) & GTK_FILE_FILTER_MIME_TYPE); + g_assert (gtk_file_filter_get_needed (filter) & GTK_FILE_FILTER_DISPLAY_NAME); + + info.filename = "test1.txt"; + info.display_name = "test1.txt"; + info.contains = GTK_FILE_FILTER_FILENAME | GTK_FILE_FILTER_DISPLAY_NAME; + g_assert (gtk_file_filter_filter (filter, &info)); + + info.mime_type = "application/x-pdf"; + info.contains = GTK_FILE_FILTER_MIME_TYPE; + g_assert (!gtk_file_filter_filter (filter, &info)); + + g_object_unref (builder); +} + int main (int argc, char **argv) { @@ -3036,6 +3078,7 @@ main (int argc, char **argv) g_test_add_func ("/Builder/No IDs", test_no_ids); g_test_add_func ("/Builder/Property Bindings", test_property_bindings); g_test_add_func ("/Builder/anaconda-signal", test_anaconda_signal); + g_test_add_func ("/Builder/FileFilter", test_file_filter); return g_test_run(); } -- 2.30.2